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dn: cn=user name, ou=organization unit , o=organizaion, c 
cn: user name 

sn: surname ' 
givenname: firstname 
mail: email address 
useraccount: user account alias 
userpassword: user password 
telephonenumber: user phone number 
roomnumber: user room number 
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import javax.naming.*; 

import javax.naming. directory.*; 

class Idapclass { 

public void add Dn (Properties IdapEntry) throws Exception{ 
/* Values we'll use in creating the entry */ 

Attribute cn = new BasicAttributefcn", (String) IdapEntry .get("fullname") ); 



/* Specify the DN we're adding 7 

String DnBase1="c="+ldapEntry.get("region"); 

String DnBase2="o="+ 

IdapEntry .get("business")+", "+DnBase1 ; 
String DnBase3="ou="+ldapEntry.get("function")+" 1 "+DnBase2; 
String dn = "cn="+(String)ldapEntry.get("fullname")+ ,, 1 "+DnBase3; 

Hashtable envir = new Hashtable(5, 0.750; 

/* Specify the initial context implementation to use. 7 



DirContext context = null; 

r Add Base DN 7 

/* Add DN*/ 
try { 

Attributes basics = new Basic Attributes(); 
basics.put(cn); 

/* Add the entry */ 

context.createSubcontext(dn, basics); 
} catch (NameAlreadyBoundException e) { . 
} catch (NamingException e) { ... 

} 



} 
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public class SignllpServlet extends HttpServlet { 



public void doPost (HttpServletRequest req, HttpServletResponse res) 
throws ServletException, lOException { 
String next=nextPage; 

Exception enext = new Exception("Your account has been created!"); 

req.setAttribute("javax.servlet.jsp.jspException",enext); 

try{ 

/* Collect user information from JSP form */ 
String username = req.getParameter("username"); 

/* Sanity Check */ 

else if (username.equals("")) { 

next=errorPage+"?"+"username="+username+"&firstname="+ 

firstname+''&middlename="+middlename+"&lastname="+lastname 

+"&emailaddress="+emailaddress 

+ "&business="+business 

+ "&function="+function 

+"&region="+region; 
Exception e = new Exception("Your username can't be empty!"); 
req.setAttribute("javax.servlet.jsp.jspException",e); 



/* Add an entry to LDAP server */ 
else { 

Properties IdapEntry = new Properties{); 
ldapEntry.put("username",username); 

Idapclass.addDn(ldapEntry); 

/* Add a mirror person to eMatrix database 7 
PersonBean person = new PersonBean(); 
person.setUsername(username); 

eMatrixRepository.put(person,bos,host); 
} 

} catch (Exception e) { 



} 



} 



} 
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public class MyProfileServlet extends HttpServlet { 



public void doPost (HttpServletRequest req, HttpServletResponse res) 
throws ServletException, lOException { 



try{ 



I' Step 1 : Authenticate user against LDAP sever 7 
String step = req.getParameterfstep"); 
if (step.equals("1")){ 

String usemame = req.getParameterfusername"); 
String password = req.getParameter("password"); 
String password2 = req.getParameter("password2"); 
/* Sanity Check and authentication 7 

if (!password.equals(password2)) 

next=errorPage+''?"+"ijsername="+username+"&step=1"; 

Exception epass = new Exception("Please confirm your password!"); 

req.setAttribute("javax.servlet.jsp.jspException",epass); 
} else if (!password.equals(ldapclass.getPassword(username))) {//Authentication 

next=errorPage+"?"+"username="+username+"&step=1"; 

Exception epass = new ExceptionfPlease verify your password!"); 

req.setAttribute("javax.servlet.jsp.jspException",epass); 
} else { 

/* Retrieve user profile from LDAP server 7 

Properties myprofile = Idapclass.getMyprofile(username); 

} "' 

/* Step 2 : Update user profile in LDAP server and eMatrix database 
} else { 

/* Update user Profile in LDAP server 7 
r Collect form information 7 

String username= req.getParameterfusername"); 

/* Sanity Check 7 

r Modify the entry in LDAP 7 
Properties IdapEntry = new Properties(); 
ldapEntry.put("usemame",username); 

ldapEntry.put("fullname",fullname); 

/* Delete the old entry 7 

Idapclass.deleteUser(username); 

r Add the new one entry 7 

ldapclass..addDn(ldapEntry); 

/* Modify mirror Person in eMatrix database 7 

PersonBean person = new PersonBean(); 

person.setUsername(username); 

eMatrixRepository.edit(person,bos,host); 
} 

} catch (Exception e) { 



} 
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public class SignlnServlet extends HttpServlet { 



public void doGet (HttpServletRequest req, HttpServletResponse res) 
throws ServletException, lOException { 



String next; 

ContextBindingListener _context; 
PersonBean user; 

/* Get the current session object, create one if necessary 7 
HttpSession session = req.getSession(true); 

try{ 

String emailpassword=req.getParameter("emailpassword"); 
/* If user need account manager send his or her password by email !7 
if (emailpassword.equals("true")) { 

emailpassword="false"; 

String _user; 

_user = req.getParameter("Username"); 
/* Retrieve password from LDAP server. 7 

String _password= ldapctass.getPassword(_user); 
/* Send email to the user 7 

Email email= new Email(); 

String emailSubject = new String(); 

emailSubject = "Your Password"; 

String emailData = new String(); 

emailData-'Your Password is: "+ .password; 

email. sendMail("STMPserver", "account manager's email address" 
/* Retrieve email address from LDAP server 7 
, ldapclass.getEmailaddress(_user), 
emailSubject.emailData); 

}eise { 
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